

# Lecture 26 – Processor design 1

Dr. Aftab M. Hussain,
Assistant Professor, PATRIOT Lab, CVEST

- A universal register is a very useful entity in processor design
- It can store value as well as have some basic arithmetic functions such as increment/decrement etc.
- The register has two input/output lines (sometimes coupled into one IO bus)
- Input lines IN are logically connected internally to the inputs of the n flipflops inside the register
- Output lines OUT are the lines that hold the value stored in the register when the register is accessed for read. The OUT lines are tristate-capable so that they can be connected to a common data bus



#### The control bits are as follows:

- The input EN controls the high-impedence state of the output lines OUT. When EN is 0, the OUT lines will be in the highimpedence state. When EN is 1, the OUT lines will be driven to the electric levels corresponding to the value stored in the register
- The input LD loads the register from the input, which changes the value stored in it.
   When LD is 1, the value indicated by the electric levels of the IN lines will replace the previous value stored in the register
- The input RESET controls resetting of the register. When RESET is 1, a 0 value will be written to all bits stored in the register. We will assume a synchronous reset.



- The control bits are as follows:
  - Inputs INC and DEC control the incrementing or decrementing the value stored in the register, interpreted as a number.
  - Inputs ROL, ROR control the left or right rotation of the register contents. This is shifting such that the last bit is feedback to the first bit
  - Inputs SHL, SHR control the left or right shift of the register contents. We assume a 0 will fill the void during the shift



- The timing diagram depends on how we design the register
- In this case, we have designed such that all instructions (actions) happen to the stored value at the negative edge of the clock
- While the EN puts the data on the output bus at the positive edge of the clock
- This makes the setup/hold more complex but can be time saving



## Creating a common bus

- Using tristate buffers, we can connect multiple input/outputs of multiple registers on the same bus
- Consider registers A and B
- The enable, load, and increment control signals of register A are respectively E<sub>A</sub>, L<sub>A</sub>, and I<sub>A</sub> and for register B are labelled E<sub>B</sub>, L<sub>B</sub>, and I<sub>B</sub>
- Let us say we need to transfer from A to B
- We enable E<sub>A</sub> and L<sub>B</sub> and in one clock cycle, the contents get transferred



## Creating a common bus

 In effect, we have moved the data to register B from register A, like a assignment instruction!

- At the level of the hardware, activating 2 signals simultaneously was all that was done
- The rest happened due to the bus connection, the clock, and the design of the register
- What if we activate L<sub>B</sub>, E<sub>D</sub>, L<sub>C</sub>, L<sub>A</sub> together?
- What if we activate E<sub>B</sub>, L<sub>A</sub>, I<sub>B</sub>



## ALU design

- Enter, The ALU!
- We generally consider an ALU as a "simple" combinational circuit capable of performing several basic functions on a set of two binary numbers – add, sub, multiply, increment, AND, OR, XOR, and many other operations based on a select input
- This is generally implemented using a combination of MUXes within the ALU



# ALU design

# • Internal architecture of ALU IC 74181

| Selection |    |    |    | Active-low inputs & outputs |                              |
|-----------|----|----|----|-----------------------------|------------------------------|
| S3        | S2 | S1 | S0 | Logic (M = 1)               | Arithmetic (M = 0) (Cn = 0)  |
| 0         | 0  | 0  | 0  | $\overline{A}$              | A minus $1$                  |
| 0         | 0  | 0  | 1  | $\overline{AB}$             | AB minus $1$                 |
| 0         | 0  | 1  | 0  | $\overline{A}+B$            | $A\overline{B}$ minus $1$    |
| 0         | 0  | 1  | 1  | Logical 1                   | -1                           |
| 0         | 1  | 0  | 0  | $\overline{A+B}$            | $A$ plus $(A+\overline{B})$  |
| 0         | 1  | 0  | 1  | $\overline{B}$              | $AB$ plus $(A+\overline{B})$ |
| 0         | 1  | 1  | 0  | $\overline{A \oplus B}$     | A minus $B$ minus $1$        |
| 0         | 1  | 1  | 1  | $A+\overline{B}$            | $A + \overline{B}$           |
| 1         | 0  | 0  | 0  | $\overline{A}B$             | A plus $(A+B)$               |
| 1         | 0  | 0  | 1  | $A \oplus B$                | A plus $B$                   |
| 1         | 0  | 1  | 0  | В                           | $A\overline{B}(A+B)$         |
| 1         | 0  | 1  | 1  | A + B                       | A + B                        |
| 1         | 1  | 0  | 0  | Logical 0                   | A plus $A$                   |
| 1         | 1  | 0  | 1  | $A\overline{B}$             | AB plus $A$                  |
| 1         | 1  | 1  | 0  | AB                          | $A\overline{B}$ plus $A$     |
| 1         | 1  | 1  | 1  | A                           | A                            |



#### ALU on a bus

- Consider the configuration which has a few registers and an ALU
- Assume all the registers are made using the multipurpose registers
- The ALU is a combinational circuit with 2 inputs and two lines to select the function to be performed
- The two select lines can be in one of 4 combinations
- We refer to them symbolically as ADD, SUB, AND, PASSO



#### ALU on a bus

- The ALU has its left input connected to the bus and the right input to a register called OR or operand register, whose inputs are connected to the bus
- The output of the ALU is connected to the input of a register called AR or accumulator register, whose output is connected to the bus
- Every register has all the control signals of our generic multipurpose register

